Django-HttpResponse、render、redirect区别 及 url 变化区别

@TOC

HttpResponse

作用为内部传递一个参数,返回给浏览器

1
2
3
4
5
from django.shortcuts import HttpResponse
def from_request(request):
# Todo
return HttpResponse('OK')

render

可接受三个参数,分别为请求request, 需要渲染的模板template,以及向模板传递的参数context,render(request, ‘template’, context)
原型

1
2
3
def render(request, template_name, context=None, content_type=None, status=None, using=None):
content = loader.render_to_string(template_name, context, request, using=using)
return HttpResponse(content, content_type, status)

使用方式

1
2
3
4
5
6
7
from django.shotcuts import render
def from_request(request):
# Todo
# return render(request, 'template.html', context)
# or
return render(request, 'template.html')

redirect

接受一个URL参数,表示让浏览器跳转去指定的URL.
原型

1
2
3
def redirect(to, *args, permanent=False, **kwargs):
redirect_class = HttpResponsePermanentRedirect if permanent else HttpResponseRedirect
return redirect_class(resolve_url(to, *args, **kwargs))

使用方式

1
2
3
4
5
from django.shotcuts import redirect
def from_request(request):
# Todo
return redirect(request, 'page')

render 与redirect 时url变化区别

urls.py中绑定了你跳转时浏览器显示的url

初学时经常使用render的形式,发现url显示为当前request绑定的url,如果处理请求后结束后渲染了新的页面不过Url并没有跳转。
例如

1
2
3
4
5
6
7
8
9
10
11
12
# urls.py
urlpatterns=[
path('from_request/', views.from_request, name='from_request')
]
# views.py
def from_request(request):
if condition1:
return render(request, 'page1.html')
else
return render(request, 'page2.html')

此时无论跳转page1还是page2 url的显示都会是 ==yoursite/from_request==

这可以归类为设计的问题,及绑定的url就应该是目的渲染的html
但如果想要跳转时url也跟着改变即可采用redirect方式重新返回绑定的url
例如

1
2
3
4
5
6
7
8
9
10
11
12
13
14
# urls.py
urlpatterns=[
path('from_request/', views.from_request, name='from_request'),
path('to_page1/', views.to_page1, name='to_page1'),
path('to_page2/', views.to_page2, name='to_page2'),
]
# views.py
def from_request(request):
if condition1:
return redirect('to_page1/')
else
return redirect('to_page2/')

这个赞赏我只是放在这里看看的,你愿意帮我测试下这个功能吗?